【linux】open函数创建新文件及umask函数使用

您所在的位置:网站首页 fopen 权限 【linux】open函数创建新文件及umask函数使用

【linux】open函数创建新文件及umask函数使用

2024-07-03 04:56| 来源: 网络整理| 查看: 265

首先我们来看一下open函数的原型

#include int open(const char *path, int oflag,.../*mode_t mode*/); //返回值:若成功,返回文件描述符;若失败,返回-1

由函数原型可知open函数有一个可变参数mode,当使用open函数创建新文件时,需选用常量O_CREAT为构成参数oflag的一部分,此时我们需要通过参数mode为新建的文件设置访问权限。

参数mode由下面9个文件访问权限位中的若干位相”或”构成。

st_mode含义S_IRUSR用户读S_IWUSR用户写S_IXUSR用户执行S_IRGRP组读S_IWGRP组写S_IXGRP组执行S_IROTH其它读S_IWOTH其它写S_IXOTH其它执行

另外mode参数也可以通过一个3位8进制数来表示,例如: S_IRUSR | S_IWUSR | S_IRGRP | S_IWOTH 可用八进制数 0642来表示 0642的二进制表示为 110 100 010 显然这个二进制数的后9位分别对应了 用户、组、其他 相应的 读、写、执行 权限

不过新建文件的访问权限并不是完全由mode参数决定的,而是要和文件模式创建屏蔽字umask经过如下计算来得到。

新的访问权限 = mode & (~umask) 文件模式创建屏蔽字umask

umask值用于控制用户所创建文件的默认权限,umask也是一个mode_t类型的值,它的每一位都代表一种要屏蔽的权限。每个进程都有自己的umask值,系统会自动为其设置一个值。通过shell的umask命令可以查看。 下面介绍umask函数,它可以为进程设置文件模式创建屏蔽字,并返回之前的值。

#include mode_t umask(mode_t cmask); //cmask为要设置的新值

下面通过一段代码说明用open函数创建新文件的过程以及umask函数的使用

#include #include #define RWRWRW (S_IRUSR|S_IWUSR|S_IRGRP|S_IWGRP|S_IROTH|S_IWOTH) int main() { umask(0); open("file1", O_CREAT, RWRWRW); umask(0077); //屏蔽组和其它的所有权限 open("file2", O_CREAT, RWRWRW); return 0; }

shell下运行结果

$ umask 0002 $ ./a.out $ ls -l file1 file2 -rw-rw-rw- 1 waiting waiting 0 12月 14 13:30 file1 -rw------- 1 waiting waiting 0 12月 14 13:30 file2 $ umask 0002

由以上的结果可以看出,修改进程的umask值并不会影响其父进程的umask值。 并且如果想要新创建文件的访问权限完全由用户决定,那么只需在调用open函数前用umask函数将umask值置为0即可。



【本文地址】


今日新闻


推荐新闻


CopyRight 2018-2019 办公设备维修网 版权所有 豫ICP备15022753号-3